<!DOCTYPE html>
<html>

<head>
  <meta charset="utf-8">
  <title>vue html demo</title>
  <script src="./lib/vue-2.4.0.js"></script>
  <style>
    .ball {
      background: red;
      width: 15px;
      height: 15px;
      border-radius: 50%
    }
  </style>
</head>

<body>
  <div id="app">

    <button @click="flag=!flag">加入购物车</button>
    <transition @before-enter="beforeEnter" @enter="enter" @after-enter="afterEnter">

      <div class="ball" v-show="flag"></div>

    </transition>
  </div>

  <script>
    var vm = new Vue({
      el: '#app',
      data: {
        flag: false
      },
      methods: {
        beforeEnter(el) {
          el.style.transform = 'translate(0,0)'
        },
        enter(el, done) {
          el.offsetWidth

          el.style.transform = 'translate(150px,450px)'
          el.style.transition = 'all 1s ease'
          done()
        },
        afterEnter(el) {
          // 这句话 第一个功能是控制小球的显示隐藏 第二个是 跳过后半场动画 让flag 变成 false 第二次点击的时候 flag false true 然后继续 false
          this.flag = !this.flag

          // vue吧一个完整的动画 使用狗子函数 拆分了2部分 我们使用 flag标识符来表示动画的切换 刚一开始 flag = false 点击后吧flag变成了 true 然后继续 flase
          // el.style.display ='none'
        }
      }
    })
  </script>
</body>

</html>